import { createApp } from "vue";
import pinia from "./stores";
import ElementPlus from "element-plus";
import zhCn from "element-plus/es/locale/lang/zh-cn";
import "element-plus/dist/index.css";
import App from "./App.vue";
import router from "./router";
import "./styles/index.scss";
import ElSvg from "./components/SvgIcon/ElSvg";
import "./permission";
import Category from "@/components/Category/index.vue";
import { useUserInfoStore } from "@/stores/userInfo";

import { vueEcharts, $echarts } from "@/utils/echarts";

import "@/mock";

const userInfoStore = useUserInfoStore();
const app = createApp(App);
app.component("Category", Category);

app.directive("role", (el, bindings) => {
  if (!userInfoStore.userInfo.buttons.includes(bindings.value)) {
    el.remove();
  }
});
ElSvg(app);

app
  .use(pinia)
  .use(router)
  .use(vueEcharts)
  .use(ElementPlus, {
    locale: zhCn,
  })
  .mount("#app");
